草庐IT

C++ 指向 vector 的指针

全部标签

c# - 如何获取指向 IShellView2 接口(interface)的指针

我们需要在我们的应用程序中托管类似资源管理器的浏览器窗口。我们不能使用新的IExplorerBrowser,因为需要保持与WindowsXP的兼容性。主要问题是我们需要默认以“大图标”模式显示项目。不幸的是,使用FOLDERSETTINGS.viewMode=0x1/*LargeIcon*/调用IShellVIew.CreateViewWindow()不会将View模式更改为所需的模式。但我可以通过窗口中的上下文菜单手动执行此操作。所以我们需要设置“大图标”View模式。我没有找到任何方法以编程方式获取View本身的上下文菜单。然后,我发现IShellView2似乎需要改进-IShel

在 Windows 核心文件上调用 fopen 返回 NULL 指针

我试图通过它们的绝对路径(在其他地方以编程方式确定)打开几个不同的文件,这样我就可以获得它们的SHA1哈希*,其中一些是核心Windows文件。当我尝试按如下方式打开文件时,fopen()在某些(但不是全部)文件上返回NULL(通常文件名是通过QueryFullProcessImageName获取的,但为了以防万一,我对其进行了硬编码):char*filename="c:\\windows\\system32\\spoolsv.exe";FILE*currFileRead=fopen(filename,"rb");if(currFileRead==NULL){printf("Faile

c++ - 使用 C++/STL 将 std::vector<CString> 展平为 multi_sz 的推荐方法是什么

我想将存储在std::vector中的字符串列表(ATL::CString)写入Windows注册表中的REG_MULTI_SZ值。我知道如何在普通C中执行此操作(迭代一次以获得总长度,分配一个缓冲区,将字符串复制到由“\0”分隔的缓冲区)。知道我使用STL尝试了以下操作(抱歉,我必须将VS2010与“foreach”一起使用):std::vectormultiline_sz;foreach(CStringentryinmyStringList){TCHAR*buf=entry.GetBuffer();multiline_sz.insert(multiline_sz.end(),&bu

c++ - undefined reference 链接器错误指向已在同一文件中的变量

我正在为链表编写代码,当我尝试使用g++进行编译时遇到了这个奇怪的错误。/cygdrive/c/Users/Blas/AppData/Local/Temp/ccEcixjp.o:Infunction`Node':/cygdrive/c/Users/Blas/Documents/blas.borde/trunk/Cs170/Lab6/List.h:50:undefinedreferenceto'CS170::ListLab::Node::nodes_alive'/cygdrive/c/Users/Blas/Documents/blas.borde/trunk/Cs170/Lab6/Lis

windows - 在 Python 的子进程中使用 Windows 路径(指向可执行文件)

我开始在安装了cygwin(Python2.7)的Windows7x64机器上开发一个小的pdf到jpg脚本。以下完美运行:importsubprocessfilename="test"subprocess.check_output('gs-sDEVICE=jpeg-dPDFFitPage-g2800x3620-o'+filename+'-2800-%03d.jpg'+filename+'.pdf',stderr=subprocess.STDOUT)在我的Windows10x64非Cygwin机器(Python2.7)上拉取此项目后,此代码出错,因为它不再将“gs”识别为ghostsc

windows - 多个 ProgID 可以指向同一个 ClsID 吗?

我正在研究一组本质上是插件的东西,它们是COM服务器。每个插件都有一组由另一个组件管理的配置数据,配置数据的主键是插件的ProgID。当插件需要访问配置项时,它会调用并传入其ProgID和所需属性的名称。这是一个遗留设计,我必须保持向后兼容性。我现在需要加载每个插件的多个实例,每个实例都有一组不同的配置数据。我正在考虑的解决方案是为每个插件创建多个唯一的ProgID,每个ProgID将指向插件的单个ClsId。因此,插件的每个实例都将由其ProgID标识,ProgID仍用作配置数据的主键,并且一切都是100%向后兼容的。那么,问题:这是一种可以接受的技术吗?(多个ProgID都指向一个

c++ - 从类指针到 long 的 reinterpret_cast

我用这些行在Win64上编写了一个C++应用程序:Window*wnd=0;longl=reinterpret_cast(wnd);编译器在最后一行显示以下错误:error:castfrom'window::Window*'to'longint'losesprecision[-fpermissive]我使用此值将其放入SetWindowLong(WindowsAPI)函数。我无法理解这个错误。我正在使用MinGW-w64(rubenbuild)。 最佳答案 阅读我的originalcomment.问题在于sizeof(window:

c - 仍然不理解 C 中指向数字数组的指针

正如标题所说,我很笨。我试图在堆上分配空间来存储uint64_t数组的值。(它可以是任何类型的数字,但这是我用来区分值和指针的数字。)我得到了我的一个问题的答案here.我觉得我懂了。我想要做的是获取一个指向数字数组的指针,然后在运行时为该数组赋值。编辑:美国东部时间下午12:15更新。为了节省阅读量,我将原始问题留在下面,并根据评论和答案将问题缩小为以下内容。这是我的C代码:#include"stdafx.h"#include#include#defineNBRPTR3intmain(){uint64_t(*LngArr3)[NBRPTR];//pointertoarrayof3ui

c++ - C++ 指针是否跨 EXE 和 DLL 工作

我有一个C++应用程序,它有许多静态ibs(*.lib)和DLL。我在我的EXE中创建一个对象,然后我使用函数调用将指向该对象的指针从一个库传递到另一个库。在这个指针从主EXE移动到DLL函数的过程中,我想知道它会不会有什么问题,或者我需要注意什么预防措施。Main.EXEwith3staticlibs(A.lib,B.lib,C.lib)Main.EXEalsolinkswith2DLL's-d1.dll,d2.dll.EachofthesestaticlibraryandDLLalsostaticallylinkstoastaticlibraryX.lib.调用流程:main()i

windows - 是否可以使用偏移指针释放内存?

假设我在内存中分配了一个包含字符串"ABCDEFG"的内存,但我只有一个指向'E'的指针。是否有可能在win32上释放该block,给定一个在block内但不在开始处的指针?任何分配方法都可以,但Heap*函数将是阻力最小的路径。如果不是native解决方案,是否有任何编写的自定义内存管理器提供此功能?编辑:这不是马虎的借口。我正在开发一个使用100%编译时元数据的自动内存管理系统。这个奇怪的要求似乎是唯一阻碍它工作的东西,即便如此,它也只需要基于数组(可切片)的数据类型。 最佳答案 运行时库中的内存分配例程可以根据每个分配bloc